package it.unipd.dei.bd.icineasti.database;

import it.unipd.dei.bd.icineasti.resource.Tariffa;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;

/**
 * Restituisce un'istanza di tariffa (di biglietto) data la fascia.
 * 
 * @author Visentin Lorenzo
 * @version 1.00
 */
public class GetTariffaDatabase {

	/**
	 * Interrogazione al database.
	 */
	private static final String STATEMENT = "SELECT Fascia, CAST(PrezzoListino AS NUMERIC), In3D " +
											"FROM Tariffa " +
											"WHERE Fascia = ?";
	
	/**
	 * Connessione al database
	 */
	private final Connection con;
	
	/**
	 * Fascia della tariffa
	 */
	private final String fascia;
	
	/**
	 * Risultato
	 */
	private Tariffa tariffa;
	
	/**
	 * Passo la fascia e ottengo le informazioni sulla tariffa (tra cui il prezzo di listino)
	 */
	public GetTariffaDatabase(Connection con, String fascia) {
		this.con = con;
		this.fascia = fascia;
	}

	public Tariffa getTariffa() throws SQLException {

		PreparedStatement pstmt = null;
		ResultSet rs = null;

		try {
			pstmt = con.prepareStatement(STATEMENT);
			pstmt.setString(1, fascia);

			rs = pstmt.executeQuery();

			rs.next();
			tariffa = new Tariffa (
									rs.getString("fascia"),
									rs.getBigDecimal("prezzoListino"),
									rs.getBoolean("in3D")
								);
		} finally {
			if (rs != null) {
				rs.close();
			}

			if (pstmt != null) {
				pstmt.close();
			}

			con.close();
		}

		return tariffa;
	}
}
